/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
<template>
  <div class="list-model">
    <div class="table-box">
      <el-table :data="list" size="mini" style="width: 100%">
        <el-table-column type="index" :label="$t('#')" width="50"></el-table-column>
        <el-table-column :label="$t('UDF Resource Name')" min-width="150" show-overflow-tooltip>
          <template slot-scope="scope">
            <a href="javascript:" class="links" @click="_go(scope.row)">{{ scope.row.alias }}</a>
          </template>
        </el-table-column>
        <el-table-column :label="$t('Whether directory')" min-width="100">
          <template slot-scope="scope">
            {{scope.row.directory? $t('Yes') : $t('No')}}
          </template>
        </el-table-column>
        <el-table-column prop="fileName" :label="$t('File Name')" min-width="150"></el-table-column>
        <el-table-column :label="$t('File Size')">
          <template slot-scope="scope">
            {{_rtSize(scope.row.size)}}
          </template>
        </el-table-column>
        <el-table-column prop="description" :label="$t('Description')" min-width="180"></el-table-column>
        <el-table-column :label="$t('Create Time')" min-width="120">
          <template slot-scope="scope">
            <span>{{scope.row.createTime | formatDate}}</span>
          </template>
        </el-table-column>
        <el-table-column :label="$t('Update Time')" min-width="120">
          <template slot-scope="scope">
            <span>{{scope.row.updateTime | formatDate}}</span>
          </template>
        </el-table-column>
        <el-table-column :label="$t('Operation')" min-width="120">
          <template slot-scope="scope">
            <el-tooltip :content="$t('Rename')" placement="top" :enterable="false">
              <span><el-button type="primary" size="mini" icon="el-icon-edit" @click="_rename(scope.row,scope.$index)"
                           circle></el-button></span>
            </el-tooltip>
            <el-tooltip :content="$t('Download')" placement="top" :enterable="false">
              <span><el-button type="primary" size="mini" icon="el-icon-download" @click="_downloadFile(scope.row)"
                           :disabled="scope.row.directory? true: false" circle></el-button></span>
            </el-tooltip>
            <el-tooltip :content="$t('Delete')" placement="top" :enterable="false">
              <el-popconfirm :confirmButtonText="$t('Confirm')" :cancelButtonText="$t('Cancel')" icon="el-icon-info"
                             iconColor="red" :title="$t('Delete?')" @onConfirm="_delete(scope.row,scope.row.id)">
                <el-button type="danger" size="mini" icon="el-icon-delete" circle slot="reference"></el-button>
              </el-popconfirm>
            </el-tooltip>
          </template>
        </el-table-column>
      </el-table>
    </div>
    <el-dialog title="重命名" :visible.sync="renameDialog" width="auto" append-to-body>
      <m-rename :item="item" @onUpDate="onUpDate" @close="close"></m-rename>
    </el-dialog>
  </div>
</template>
<script>
  import { mapActions } from 'vuex'
  import mRename from './rename'
  import { downloadFile } from '@/module/download'
  import { bytesToSize } from '@/module/util/util'
  import localStore from '@/module/util/localStorage'

  export default {
    name: 'udf-manage-list',
    data () {
      return {
        list: [],
        renameDialog: false,
        index: null
      }
    },
    props: {
      udfResourcesList: Array,
      pageNo: Number,
      pageSize: Number
    },
    methods: {
      ...mapActions('resource', ['deleteResource']),
      _downloadFile (item) {
        downloadFile(`resources/${item.id}/download`, { Authorization: sessionStorage.getItem('sessionId'), fileName: item.alias })
      },
      _go (item) {
        localStore.setItem('file', `${item.alias}|${item.size}`)
        if (item.directory) {
          localStore.setItem('currentDir', `${item.fullName}`)
          this.$router.push({ path: `/resource/udf/subUdfDirectory/${item.id}` })
        }
      },
      _rtSize (val) {
        return bytesToSize(parseInt(val))
      },
      _closeDelete (i) {
        this.$refs[`poptip-${i}`][0].doClose()
      },
      _delete (item, i) {
        this.deleteResource({
          id: item.id
        }).then(res => {
          this.$emit('on-update')
          this.$message.success(res.msg)
        }).catch(e => {
          this.$message.error(e.msg || '')
        })
      },
      _rename (item, i) {
        this.item = item
        this.index = i
        this.renameDialog = true
      },
      onUpDate (item) {
        this.$set(this.list, this.index, item)
        this.renameDialog = false
      },

      close () {
        this.renameDialog = false
      }
    },
    watch: {
      udfResourcesList (a) {
        this.list = []
        setTimeout(() => {
          this.list = a
        })
      }
    },
    created () {
    },
    mounted () {
      this.list = this.udfResourcesList
    },
    components: { mRename }
  }
</script>
